package co.yixiang.modules.shop.service;

import co.yixiang.modules.shop.domain.YxGoods;
import co.yixiang.modules.shop.domainExcel.YxGoodsExcelData;
import co.yixiang.modules.shop.service.dto.YxGoodsDto;
import co.yixiang.modules.shop.service.dto.YxGoodsQueryCriteria;
import org.springframework.data.domain.Pageable;
import java.io.InputStream;
import java.util.Map;
import java.util.List;
import java.io.IOException;
import javax.servlet.http.HttpServletResponse;

/**
* @author frq
* @date 2020-08-24
*/
public interface YxGoodsService {

    /**
    * 查询数据分页
    * @param criteria 条件
    * @param pageable 分页参数
    * @return Map<String,Object>
    */
    Map<String,Object> queryAll(YxGoodsQueryCriteria criteria, Pageable pageable);

    /**
    * 查询所有数据不分页
    * @param criteria 条件参数
    * @return List<YxGoodsDto>
    */
    List<YxGoodsDto> queryAll(YxGoodsQueryCriteria criteria);


    /**
    * 导出数据
    * @param all 待导出的数据
    * @param response /
    * @throws IOException /
    */
    void download(List<YxGoodsDto> all, HttpServletResponse response) throws IOException;

    /**
     * 打批量导入
     * @param inputStream
     */
    void doEasyExcelImportGoods(InputStream inputStream);

    /**
     * 查询所有数据
     * @return
     */
    List<YxGoodsExcelData> findListYxGoods();

    /**
     * poi批量导入
     * @param list
     */
    void doPOIImportGoods(List<List<String>> list);
}